<template v-if="showCards">
  <div class="text-center">
    <!-- Total Time -->
    <div v-if="validateTotalTime" class="time-card-flex mx-auto">
      <v-row no-gutters class="d-flex flex-no-wrap align-center " :style="fontSize">
        <v-icon :x-large="!small" left color="primary">
          {{ $globals.icons.clockOutline }}
        </v-icon>
        <p class="my-0"><span class="font-weight-bold">{{ validateTotalTime.name }}</span><br>{{ validateTotalTime.value }}</p>
      </v-row>
    </div>
    <v-divider v-if="validateTotalTime && (validatePrepTime || validatePerformTime)" class="my-2" />
    <!-- Prep Time & Perform Time -->
    <div v-if="validatePrepTime || validatePerformTime" class="time-card-flex mx-auto">
      <v-row
        no-gutters
        class="d-flex justify-center align-center" :class="{'flex-column': $vuetify.breakpoint.smAndDown}"
        style="width: 100%;" :style="fontSize"
      >
        <div v-if="validatePrepTime" class="d-flex flex-no-wrap my-1">
          <v-icon :large="!small" :dense="small" left color="primary">
            {{ $globals.icons.knfife }}
          </v-icon>
          <p class="my-0"><span class="font-weight-bold">{{ validatePrepTime.name }}</span><br>{{ validatePrepTime.value }}</p>
        </div>
        <v-divider v-if="validatePrepTime && validatePerformTime" vertical class="mx-4" />
        <div v-if="validatePerformTime" class="d-flex flex-no-wrap my-1">
          <v-icon :large="!small" :dense="small" left color="primary">
            {{ $globals.icons.potSteam }}
          </v-icon>
          <p class="my-0"><span class="font-weight-bold">{{ validatePerformTime.name }}</span><br>{{ validatePerformTime.value }}</p>
        </div>
      </v-row>
    </div>
  </div>
</template>

<script lang="ts">
import { computed, defineComponent, useContext } from "@nuxtjs/composition-api";

export default defineComponent({
  props: {
    prepTime: {
      type: String,
      default: null,
    },
    totalTime: {
      type: String,
      default: null,
    },
    performTime: {
      type: String,
      default: null,
    },
    color: {
      type: String,
      default: "accent custom-transparent"
    },
    small: {
      type: Boolean,
      default: false,
    },
  },
  setup(props) {
    const { i18n } = useContext();

    function isEmpty(str: string | null) {
      return !str || str.length === 0;
    }

    const showCards = computed(() => {
      return [props.prepTime, props.totalTime, props.performTime].some((x) => !isEmpty(x));
    });

    const validateTotalTime = computed(() => {
      return !isEmpty(props.totalTime) ? { name: i18n.t("recipe.total-time"), value: props.totalTime } : null;
    });

    const validatePrepTime = computed(() => {
      return !isEmpty(props.prepTime) ? { name: i18n.t("recipe.prep-time"), value: props.prepTime } : null;
    });

    const validatePerformTime = computed(() => {
      return !isEmpty(props.performTime) ? { name: i18n.t("recipe.perform-time"), value: props.performTime } : null;
    });

    const fontSize = computed(() => {
      return props.small ? { fontSize: "smaller" } : { fontSize: "larger" };
    });

    return {
      showCards,
      validateTotalTime,
      validatePrepTime,
      validatePerformTime,
      fontSize,
    };
  },
});
</script>

<style scoped>
.time-card-flex {
  width: fit-content;
}
.custom-transparent {
  opacity: 0.7;
}
</style>
